home *** CD-ROM | disk | FTP | other *** search
/ Aminet 2 / Aminet AMIGA CDROM (1994)(Walnut Creek)[Feb 1994][W.O. 44790-1].iso / Aminet / util / gnu / emacs_src.lha / emacs-18.58 / lisp / mim-mode.elc < prev    next >
Text File  |  1992-02-21  |  20KB  |  300 lines

  1.  
  2. (provide (quote mim-mode))
  3.  
  4. (autoload (quote fast-syntax-check-mim) "mim-syntax" "\
  5. Checks Mim syntax quickly.
  6. Answers correct or incorrect, cannot point out the error context." t)
  7.  
  8. (autoload (quote slow-syntax-check-mim) "mim-syntax" "\
  9. Check Mim syntax slowly.
  10. Points out the context of the error, if the syntax is incorrect." t)
  11.  
  12. (defvar mim-mode-hysterical-bindings t "\
  13. *Non-nil means bind list manipulation commands to Meta keys as well as
  14. Control-Meta keys for historical reasons.  Otherwise, only the latter keys
  15. are bound.")
  16.  
  17. (defvar mim-mode-map nil)
  18.  
  19. (defvar mim-mode-syntax-table nil)
  20.  
  21. (if mim-mode-syntax-table nil (let ((i -1)) (setq mim-mode-syntax-table (make-syntax-table)) (while (< i 32) (modify-syntax-entry (setq i (1+ i)) "    " mim-mode-syntax-table)) (while (< i 127) (modify-syntax-entry (setq i (1+ i)) "_   " mim-mode-syntax-table)) (setq i (1- 97)) (while (< i 122) (modify-syntax-entry (setq i (1+ i)) "w   " mim-mode-syntax-table)) (setq i (1- 65)) (while (< i 90) (modify-syntax-entry (setq i (1+ i)) "w   " mim-mode-syntax-table)) (setq i (1- 48)) (while (< i 57) (modify-syntax-entry (setq i (1+ i)) "w   " mim-mode-syntax-table)) (modify-syntax-entry 58 "     " mim-mode-syntax-table) (modify-syntax-entry 44 "'    " mim-mode-syntax-table) (modify-syntax-entry 46 "'    " mim-mode-syntax-table) (modify-syntax-entry 39 "'    " mim-mode-syntax-table) (modify-syntax-entry 96 "'    " mim-mode-syntax-table) (modify-syntax-entry 126 "'    " mim-mode-syntax-table) (modify-syntax-entry 59 "'    " mim-mode-syntax-table) (modify-syntax-entry 35 "'    " mim-mode-syntax-table) (modify-syntax-entry 37 "'    " mim-mode-syntax-table) (modify-syntax-entry 33 "'    " mim-mode-syntax-table) (modify-syntax-entry 34 "\"   " mim-mode-syntax-table) (modify-syntax-entry 92 "\\   " mim-mode-syntax-table) (modify-syntax-entry 40 "()  " mim-mode-syntax-table) (modify-syntax-entry 60 "(>  " mim-mode-syntax-table) (modify-syntax-entry 123 "(}  " mim-mode-syntax-table) (modify-syntax-entry 91 "(]  " mim-mode-syntax-table) (modify-syntax-entry 41 ")(  " mim-mode-syntax-table) (modify-syntax-entry 62 ")<  " mim-mode-syntax-table) (modify-syntax-entry 125 "){  " mim-mode-syntax-table) (modify-syntax-entry 93 ")[  " mim-mode-syntax-table)))
  22.  
  23. (defconst mim-whitespace "- ")
  24.  
  25. (defvar mim-mode-hook nil "\
  26. *User function run after mim mode initialization.  Usage:
  27. (setq mim-mode-hook '(lambda () ... your init forms ...)).")
  28.  
  29. (define-abbrev-table (quote mim-mode-abbrev-table) nil)
  30.  
  31. (defconst indent-mim-hook (quote indent-mim-hook) "\
  32. Controls (via properties) indenting of special forms.
  33. (put 'FOO 'indent-mim-hook n), integer n, means lines inside
  34. <FOO ...> will be indented n spaces from start of form.
  35. (put 'FOO 'indent-mim-hook 'DEFINE) is like above but means use
  36. value of mim-body-indent as offset from start of form.
  37. (put 'FOO 'indent-mim-hook <cons>) where <cons> is a list or pointted list
  38. of integers, means indent each form in <FOO ...> by the amount specified
  39. in <cons>.  When <cons> is exhausted, indent remaining forms by
  40. mim-body-indent unless <cons> is a pointted list, in which case the last
  41. cdr is used.  Confused? Here is an example:
  42. (put 'FROBIT 'indent-mim-hook '(4 2 . 1))
  43. <FROBIT
  44.      <CHOMP-IT>
  45.    <CHOMP-SOME-MORE>
  46.   <DIGEST>
  47.   <BELCH>
  48.   ...>
  49. Finally, the property can be a function name (read the code).")
  50.  
  51. (defvar indent-mim-comment t "\
  52. *Non-nil means indent string comments.")
  53.  
  54. (defvar mim-body-indent 2 "\
  55. *Amount to indent in special forms which have DEFINE property on
  56. indent-mim-hook.")
  57.  
  58. (defvar indent-mim-arglist t "\
  59. *nil means indent arglists like ordinary lists.
  60. t means strings stack under start of arglist and variables stack to
  61. right of them.  Otherwise, strings stack under last string (or start
  62. of arglist if none) and variables stack to right of them.
  63. Examples (for values 'stack, t, nil):
  64.  
  65. (FOO \"OPT\" BAR             (FOO \"OPT\" BAR            (FOO \"OPT\" BAR
  66.            BAZ MUMBLE                 BAZ MUMBLE      BAZ MUMBLE
  67.      \"AUX\"                  \"AUX\"                     \"AUX\"
  68.      BLETCH ...             BLETCH ...                BLETCH ...")
  69.  
  70. (put (quote DEFINE) (quote indent-mim-hook) (quote DEFINE))
  71.  
  72. (put (quote DEFMAC) (quote indent-mim-hook) (quote DEFINE))
  73.  
  74. (put (quote BIND) (quote indent-mim-hook) (quote DEFINE))
  75.  
  76. (put (quote PROG) (quote indent-mim-hook) (quote DEFINE))
  77.  
  78. (put (quote REPEAT) (quote indent-mim-hook) (quote DEFINE))
  79.  
  80. (put (quote CASE) (quote indent-mim-hook) (quote DEFINE))
  81.  
  82. (put (quote FUNCTION) (quote indent-mim-hook) (quote DEFINE))
  83.  
  84. (put (quote MAPF) (quote indent-mim-hook) (quote DEFINE))
  85.  
  86. (put (quote MAPR) (quote indent-mim-hook) (quote DEFINE))
  87.  
  88. (put (quote UNWIND) (quote indent-mim-hook) (cons (* 2 mim-body-indent) mim-body-indent))
  89.  
  90. (defvar mim-down-parens-only t "\
  91. *nil means treat ADECLs and ATOM trailers like structures when
  92. moving down a level of structure.")
  93.  
  94. (defvar mim-stop-for-slop t "\
  95. *Non-nil means {next previous}-mim-object consider any
  96. non-whitespace character in column 0 to be a toplevel object, otherwise
  97. only open paren syntax characters will be considered.")
  98.  
  99. (fset (quote mdl-mode) (quote mim-mode))
  100.  
  101. (defun mim-mode nil "\
  102. Major mode for editing Mim (MDL in MDL) code.
  103. Commands:
  104.     If value of mim-mode-hysterical-bindings is non-nil, then following
  105. commands are assigned to escape keys as well (e.g. M-f = M-C-f).
  106. The default action is bind the escape keys.
  107.   Tab        Indents the current line as MDL code.
  108.   Delete     Converts tabs to spaces as it moves back.
  109.   M-C-f      Move forward over next mim object.
  110.   M-C-b      Move backward over previous mim object.
  111.   M-C-p      Move to beginning of previous toplevel mim object.
  112.   M-C-n      Move to the beginning of the next toplevel mim object.
  113.   M-C-a      Move to the top of surrounding toplevel mim form.
  114.   M-C-e      Move to the end of surrounding toplevel mim form.
  115.   M-C-u      Move up a level of mim structure backwards.
  116.   M-C-d      Move down a level of mim structure forwards.
  117.   M-C-t      Transpose mim objects on either side of point.
  118.   M-C-k      Kill next mim object.
  119.   M-C-h      Place mark at end of next mim object.
  120.   M-C-o      Insert a newline before current line and indent.
  121.   M-Delete   Kill previous mim object.
  122.   M-^        Join current line to previous line.
  123.   M-\\        Delete whitespace around point.
  124.   M-;        Move to existing comment or insert empty comment if none.
  125.   M-Tab      Indent following mim object and all contained lines.
  126. Other Commands:
  127.   Use \\[describe-function] to obtain documentation.
  128.   replace-in-mim-object  find-mim-definition  fast-syntax-check-mim
  129.   slow-syntax-check-mim  backward-down-mim-object  forward-up-mim-object
  130. Variables:
  131.   Use \\[describe-variable] to obtain documentation.
  132.   mim-mode-hook  indent-mim-comment  indent-mim-arglist  indent-mim-hook
  133.   mim-body-indent  mim-down-parens-only  mim-stop-for-slop
  134.   mim-mode-hysterical-bindings
  135. Entry to this mode calls the value of mim-mode-hook if non-nil." (interactive) (byte-code "ˆՠˆ?…ùÖ ‰ˆ×ØÙ#ˆ×ÚÛ#ˆ×ÜÝ#ˆ×Þß#ˆ×àá#ˆ×âã#ˆ×äå#ˆ×æç#ˆ×èé#ˆ×êë#ˆ×ìí#ˆ×îï#ˆ×ðñ#ˆ×òó#ˆ×ôõ#ˆ×ö÷#ˆ×øù#ˆ×úû#ˆ×üý#ˆ×þÿ#ˆ×@Û#ˆ    ?ƒ˜Â‚ùׁAB#ˆ×CÙ#ˆ×DÝ#ˆ×Eß#ˆ×Fá#ˆ×Gã#ˆ×Hå#ˆ×Iç#ˆ×Jé#ˆ×Kí#ˆ×Lï#ˆ×Mñ#ˆN!ˆO !ˆPÄ!ˆQP‰ˆPÆ!ˆ ‰ˆPÇ!ˆÈ‰ˆPÉ!ˆR‰    ˆPÊ!ˆR‰
  136. ˆPË!ˆS‰ ˆPÌ!ˆT‰ ˆPÍ!ˆU‰ˆPÎ!ˆÿ‰ˆPÏ!ˆÂ‰ˆPÐ!ˆÈ‰ˆ‰ˆV‰ˆW‰ˆXY!‡" [mim-mode-map mim-mode-hysterical-bindings nil mim-mode-syntax-table paragraph-start page-delimiter paragraph-separate paragraph-ignore-fill-prefix t comment-start comment-start-skip comment-end comment-column comment-indent-hook indent-line-function blink-matching-paren-distance indent-tabs-mode local-abbrev-table mim-mode-abbrev-table major-mode mode-name kill-all-local-variables make-sparse-keymap define-key "" open-mim-line "" indent-mim-object "" previous-mim-object "" next-mim-object "" beginning-of-DEFINE "" end-of-DEFINE "" transpose-mim-objects "" backward-up-mim-object "" forward-down-mim-object "" mark-mim-object " " forward-kill-mim-object "" forward-mim-object "" backward-mim-object "^" raise-mim-line "\\" fixup-whitespace "" backward-delete-char-untabify "" backward-kill-mim-object "
  137. " newline-and-mim-indent "" begin-mim-comment "    " indent-mim-line "    " "!" line-to-top-of-window "o" "p" "n" "a" "e" "t" "u" "d" "k" "f" "b" use-local-map set-syntax-table make-local-variable "^$\\|" ";\"" "\"" 40 indent-mim-comment mim-mode "Mim" run-hooks mim-mode-hook] 50))
  138.  
  139. (defun line-to-top-of-window nil "\
  140. Move current line to top of window." (interactive) (byte-code "ÀˆÁÂ!‡" [nil recenter 0] 2))
  141.  
  142. (defun forward-mim-object (arg) "\
  143. Move forward across Mim object.
  144. With ARG, move forward that many objects." (interactive "p") (byte-code "ˆÃ!ÄUƒÅ ƒÆ!‚ÇÁ\"‚Ç!‡" [arg t nil abs 1 inside-atom-p forward-sexp forward-mim-objects] 6))
  145.  
  146. (defun inside-atom-p nil (byte-code "hgÂ!ÃU†Â!ÄU†ÅU…-    !ÃU†-    !ÄU†-    ÅU*‡" [c1 c2 char-syntax 119 95 33] 6))
  147.  
  148. (defun forward-mim-objects (arg &optional skip-bracket-p) (byte-code "    !ÃÄŏˆ`Æ!U…Ç[!)‡" [direction arg sign conditions (byte-code "ÂÃ\"…Ä    !ˆÅ    !?…    Z‰ˆ‚‡" [arg direction /= 0 forward-sexp inside-adecl-or-trailer-p] 6) ((error (byte-code "?ƒÃÄ    A\"‚Å
  149. !ˆ`
  150. \\b‡" [skip-bracket-p conditions direction signal error skip-mim-whitespace] 4))) buffer-end skip-mim-whitespace] 4))
  151.  
  152. (defun backward-mim-object (&optional arg) "\
  153. Move backward across Mim object.
  154. With ARG, move backward that many objects." (interactive "p") (byte-code "ÁˆÂƒ [‚Ã!‡" [arg nil forward-mim-object -1] 2))
  155.  
  156. (defun mark-mim-object (&optional arg) "\
  157. Mark following Mim object.
  158. With ARG, mark that many following (preceding, ARG < 0) objects." (interactive "p") (byte-code "ÁˆÂŠÃ†
  159. Ä!ˆ`)!‡" [arg nil push-mark forward-mim-object 1] 3))
  160.  
  161. (defun forward-kill-mim-object (&optional arg) "\
  162. Kill following Mim object.
  163. With ARG, kill that many objects." (interactive "*p") (byte-code "ÁˆÂ`Æ
  164. Ä!ˆ`\"‡" [arg nil kill-region forward-mim-object 1] 4))
  165.  
  166. (defun backward-kill-mim-object (&optional arg) "\
  167. Kill preceding Mim object.
  168. With ARG, kill that many objects." (interactive "*p") (byte-code "ÁˆÂ†Ã[!‡" [arg nil forward-kill-mim-object 1] 2))
  169.  
  170. (defun raise-mim-line (&optional arg) "\
  171. Raise following line, fixing up whitespace at join.
  172. With ARG raise that many following lines.
  173. A negative ARG will raise current line and previous lines." (interactive "*p") (byte-code "ÈĠ   †
  174. ʼn!    ÆVƒłÆŠÇ    Æ\"…6È
  175. !ˆÉ``S\"ˆÊ ˆ    Z‰ˆ‚)*‡" [increment arg direction nil sign 1 0 /= forward-line delete-region fixup-whitespace] 8))
  176.  
  177. (defun forward-down-mim-object (&optional arg) "\
  178. Move down a level of Mim structure forwards.
  179. With ARG, move down that many levels forwards (backwards, ARG < 0)." (interactive "p") (byte-code "ĈŠ   †
  180. Ɖ!Ç    !ÆU…
  181. ?ƒ[ŠÈ!ˆÉV…'ÊË!ˆÌ!Í !ÎU†9Í !ÏU)…HÐ!ˆÑ!…H`†VÒ`Ó#†VÔ!)b‚xÕ    É\"…xÒ`Ó#†mÔ!bˆ    Z‰ˆ‚[)‡" [direction arg mim-down-parens-only c nil sign 1 abs skip-mim-whitespace 0 re-search-forward "\\s'*" next-char char-syntax 95 119 forward-sexp inside-adecl-or-trailer-p scan-lists -1 buffer-end /=] 17))
  182.  
  183. (defun backward-down-mim-object (&optional arg) "\
  184. Move down a level of Mim structure backwards.
  185. With ARG, move down that many levels backwards (forwards, ARG < 0)." (interactive "p") (byte-code "ÁˆÂƒ [‚Ã!‡" [arg nil forward-down-mim-object -1] 2))
  186.  
  187. (defun forward-up-mim-object (&optional arg) "\
  188. Move up a level of Mim structure forwards
  189. With ARG, move up that many levels forwards (backwards, ARG < 0)." (interactive "p") (byte-code "ˆà   †
  190. ĉ!Å    Æ\"…)Ç`Ä#†È    !bˆ    Z‰ˆ‚ ˆÆW…2É )‡" [direction arg nil sign 1 /= 0 scan-lists buffer-end backward-prefix-chars] 7))
  191.  
  192. (defun backward-up-mim-object (&optional arg) "\
  193. Move up a level of Mim structure backwards
  194. With ARG, move up that many levels backwards (forwards, ARG > 0)." (interactive "p") (byte-code "ÁˆÂƒ [‚Ã!‡" [arg nil forward-up-mim-object -1] 2))
  195.  
  196. (defun replace-in-mim-object (old new) "\
  197. Replace string in following Mim object." (interactive "*sReplace in object: 
  198. sReplace %s with: ") (byte-code "ˆŒÃ`ŠÄÅ!ˆ`)\"ˆÆ    \")‡" [old new nil narrow-to-region forward-mim-object 1 replace-string] 5))
  199.  
  200. (defun transpose-mim-objects (&optional arg) "\
  201. Transpose Mim objects around point.
  202. With ARG, transpose preceding object that many times with following objects.
  203. A negative ARG will transpose backwards." (interactive "*p") (byte-code "ÁˆÂÆ    Ä\"‡" [arg nil transpose-subr forward-mim-object 1] 3))
  204.  
  205. (defun beginning-of-DEFINE (&optional arg move) "\
  206. Move backward to beginning of surrounding or previous toplevel Mim form.
  207. With ARG, do it that many times.  Stops at last toplevel form seen if buffer
  208. end is reached." (interactive "p") (byte-code "ĈŠ   †
  209. Ɖ!
  210. ?…ɈÇW…`TbˆÈ    Ç\"…,ÉÊÄ
  211. $…8    Z‰ˆ‚ˆÇW…B`Sb)‡" [direction arg move t nil sign 1 0 /= re-search-backward "^<"] 7))
  212.  
  213. (defun end-of-DEFINE (&optional arg) "\
  214. Move forward to end of surrounding or next toplevel mim form.
  215. With ARG, do it that many times.  Stops at end of last toplevel form seen
  216. if buffer end is reached." (interactive "p") (byte-code "Áˆ?…
  217. ‰ˆÃWƒÄS[!‚.ÅÆ!?…$T‰ˆÄ[Ç\"ˆÄÂ!ˆÈÂ!ˆÉÂ!‡" [arg nil 1 0 beginning-of-DEFINE looking-at "^<" move forward-mim-object forward-line] 7))
  218.  
  219. (defun next-mim-object (&optional arg) "\
  220. Move to beginning of next toplevel Mim object.
  221. With ARG, do it that many times.  Stops at last object seen if buffer end
  222. is reached." (interactive "p") (byte-code "Ĉ    ƒ
  223. Ƃ ÇÈ †ɉ!
  224. ÊV…`TbˆË Ê\"…-ÌÄÅ
  225. $…9
  226. Z‰ˆ‚ ˆ
  227. ÊV…C`Sbˆ
  228. ÊW†SŠÍÉ!ˆÎ`!)?…ZÏÊ!*‡" [search-string mim-stop-for-slop direction arg nil t "^\\S " "^\\s(" sign 1 0 /= re-search-forward forward-mim-object pos-visible-in-window-p recenter] 7))
  229.  
  230. (defun previous-mim-object (&optional arg) "\
  231. Move to beginning of previous toplevel Mim object.
  232. With ARG do it that many times.  Stops at last object seen if buffer end
  233. is reached." (interactive "p") (byte-code "ÁˆÂ†Ã[!‡" [arg nil next-mim-object 1] 2))
  234.  
  235. (defun calculate-mim-indent (&optional parse-start) "\
  236. Calculate indentation for Mim line.  Returns column." (byte-code "ŠÓ ˆ`ÌÌÌÌÌÌÌÌÌ    
  237. ƒ'
  238. b‚*ÔՍˆ`W…<Ö`×#‰ˆ‚+ˆË‰ˆ    …Q
  239. @‰    …Q    ×V…$̉ˆØÙ
  240. \"@‰ˆ
  241. A@‰ˆ Tbˆ …q `V…ŠÖ ×#‰ˆA@‰…Š‰ˆ    ƒ“Ì‚  T‰ˆbˆ ?ƒ¨i‰‚ hÚUƒÛÜ!ˆ` Vƒ¾b‚ŠÝÜ!ˆ`) VƒÕÞß!ˆ`‰‚ bˆÓ ˆÖ` ×Ë$ˆ` U†òŠÖ` ×#@×U)ƒÿࠈ`‰‚b‚ …=háU…=Š×‰ˆâã!ˆT‰äW…)Ìå揅1̈‚ˆäW…<çè!)ƒØ×Ì` W…¢Þ \"ˆ`‰V…p^‰ˆé ˆ`‰ˆbˆgêUƒ›`‰ˆÛÜ!ˆ UƒŽ ‰‚˜Þ \"ˆ`‰‚žÛÜ!ˆ‚FˆbˆÞßd\"ˆgêU…Ì…¼ëË\"?ƒÇ‰‚Ì T‰*ˆbˆi‰‚ ŠÝÜ!ˆ`) VƒïÞß!ˆ`‰‚ bˆÓ ˆÖ` ×Ë$ˆ` U† ŠÖ` ×#@×U)ƒࠈ`‰‚bˆi‰ˆ‚AˆØì
  242. \"@…u ƒB bˆÛÜ!ˆíî!ˆâã!‚Lbˆïð!ˆâÜ!ˆ`‰ˆñß!ˆà ˆçò!…aƒkTb‚qbˆÞß!ˆi‰ˆ†’…Œ    ?…Œó
  243. #‰†’i‰ˆbˆ.
  244. )‡" [indent-point retry state containing-sexp last-sexp desired-indent start peek where paren-depth parse-start t nil indent-mim-arglist eol last-string mim-whitespace indent-mim-comment indent-mim-hook beginning-of-line from-the-top (byte-code "Á‰ˆ…0ÃÅƏˆÇÈ!…!
  245. bˆÉÊÃËÌ$ˆÍÎÃ\"ˆ…*ÏiÐ\"‰ˆ‚ˆÑ !ˆo?…=ÒÓ!ˆÔ ‡" [retry t indent-point nil mim-whitespace (byte-code "ÀÁ!‡" [forward-sexp -1] 2) ((error (byte-code "Á‰‡" [retry nil] 2))) looking-at ".?[     ]*\"" re-search-backward "^\\s(" move 1 throw from-the-top /= 0 skip-chars-backward forward-char -1 backward-prefix-chars] 8) parse-partial-sexp 0 nthcdr 2 60 forward-sexp 1 forward-line skip-chars-forward "     " backward-prefix-chars 40 forward-char -1 6 (byte-code "ÁÂ!ˆÀ‡" [t forward-sexp -1] 2) ((error (byte-code "À‡" [nil] 1))) looking-at "DEFINE\\|DEFMAC\\|FUNCTION" end-of-line 34 equal 3 search-forward "\"" re-search-backward "[^\\]\"" skip-chars-backward ";[     ]*\"" funcall] 40))
  246.  
  247. (defun indent-mim-hook (state indent-point) "\
  248. Compute indentation for Mim special forms.  Returns column or nil." (byte-code "    A@`ŠTbˆÈ ˆÉÊ!…oiËÌ`ÍÎ!ˆ`\"! ÏNÐÑ\"…0‰†6Ò!ƒMÓÎ!ˆ`ÔÕ    \"@V…J \\‚n
  249. bˆ:ƒ]Ö    \"‚n9…e×!…nØ    #+)*‡" [containing-sexp state current-indent start function method mim-body-indent indent-point backward-prefix-chars looking-at "\\sw\\|\\s_" intern-soft buffer-substring forward-sexp 1 indent-mim-hook equal DEFINE integerp forward-line nthcdr 2 indent-mim-offset fboundp funcall] 15))
  250.  
  251. (defun indent-mim-offset (state indent-point) (byte-code "
  252. ÉN A@ÊË \"@È Tbˆ`W…\"ÈÌ͏…PÎÏ!ˆÐ ˆgÑUƒ6ȂL    @‰ˆÒ    A‰!…L    ‰ˆÈ‰ˆ‚ˆ Tbˆi†\\\\-‡" [mim-body-indent indentations function containing-sexp state last-sexp indentation indent-point nil indent-mim-hook nthcdr 2 (byte-code "ÂÃ!ˆÄ`ÃÁ$‡" [indent-point t forward-sexp 1 parse-partial-sexp] 6) ((error (byte-code "À‡" [nil] 1))) skip-chars-backward "     " backward-prefix-chars 59 integerp] 7))
  253.  
  254. (defun indent-mim-comment (&optional start) "\
  255. Indent a one line (string) Mim comment following object, if any." (byte-code "`Ä ˆ`ÅÅÆ ˆÇȍˆb,‡" [old-point eol state last-sexp end-of-line nil beginning-of-line no-comment (byte-code "Æ`    \"‰ˆÇÈ\"@‰?†ÇÉ\"@…ÊËÃ\"ˆÌ ˆÆ`    ÍÄ$ˆ`
  256. U…3ÊËÄ\"ˆ
  257. bˆÎÏ!ˆÐ ˆÑÒ!?…IÊËÃ\"ˆÓ ˆiWƒXj‚ZÔ ‡" [state eol last-sexp nil t comment-column parse-partial-sexp nthcdr 2 3 throw no-comment beginning-of-line 0 skip-chars-backward "     " backward-prefix-chars looking-at ";[     ]*\"" delete-horizontal-space tab-to-tab-stop] 14)] 4))
  258.  
  259. (defun indent-mim-line nil "\
  260. Indent line of Mim code." (interactive "*") (byte-code "Èd`ZÄ ˆ`Å ÆÇ!ˆÈi
  261. \"… É    `\"ˆ
  262. jˆdZ`V…-dZb+‡" [position bol indent nil beginning-of-line calculate-mim-indent skip-chars-forward "     " /= delete-region] 7))
  263.  
  264. (defun newline-and-mim-indent nil "\
  265. Insert newline at point and indent." (interactive "*") (byte-code "ÀˆÁ ˆÂ ‡" [nil newline indent-mim-line] 3))
  266.  
  267. (defun open-mim-line (&optional lines) "\
  268. Insert newline before point and indent.
  269. With ARG insert that many newlines." (interactive "*p") (byte-code "ˆàˆÄ     ÅV… Æ ˆÇÈ!ˆjˆ    S‰ˆ‚)‡" [indent lines nil beginning-of-line calculate-mim-indent 0 newline forward-line -1] 7))
  270.  
  271. (defun indent-mim-object (&optional dont-indent-first-line) "\
  272. Indent object following point and all lines contained inside it.
  273. With ARG, idents only contained lines (skips first line)." (interactive "*P") (byte-code "LjÇÇÇÇŠÈ`dÉÄ$ˆ`‰ˆÊË!ˆd`Z‰)ˆŠ?…)Ì ˆÍË!ˆd`ZV…^Î !‰ˆ`‰ˆÏÐ!ˆÑ
  274. i\"…RÒ    `\"ˆ
  275. jˆ…ZÆ ˆ‚*),‡" [end bol indent start t dont-indent-first-line indent-mim-comment nil parse-partial-sexp 0 forward-sexp 1 indent-mim-line forward-line calculate-mim-indent skip-chars-forward "     " /= delete-region] 11))
  276.  
  277. (defun find-mim-definition (name) "\
  278. Search for definition of function, macro, or gfcn.
  279. You need type only enough of the name to be unambiguous." (interactive "sName: ") (byte-code "ÁˆÁŠebˆÁÂÏ)ˆ…Ä ˆbˆÅ ˆÆÇ!)‡" [where nil (byte-code "ÂÃP!ˆ`‰‡" [name where re-search-forward "^<\\(DEFINE\\|\\DEFMAC\\|FCN\\|GFCN\\)\\([     ]*\\)"] 3) ((error (byte-code "ÁÂ\"‡" [name error "Can't find %s"] 3))) push-mark beginning-of-line recenter 0] 4))
  280.  
  281. (defun begin-mim-comment nil "\
  282. Move to existing comment or insert empty comment." (interactive "*") (byte-code "Ljˠˆ`Ì ˆ`ÍÎÂ#ƒ' …$d`Zàˆd Zb)‚‘ÇÇ    bˆÏÐ`Ñ#‰@Ñ\"…BÒÓ\"@…QÒÓ\"@‰ˆ‚/ˆÒÔ\"@ƒ^ǂÕ`\"ˆ?…nÏ@Ñ\"ƒwÖ j‚†iVƒƒ× ‚†jˆ    cˆŠ
  283. c)**‡" [eol bol t indent-mim-comment where state last-sexp nil comment-column comment-start comment-end end-of-line beginning-of-line re-search-forward ";[     ]*\"" equal parse-partial-sexp 0 nthcdr 2 3 delete-region calculate-mim-indent tab-to-tab-stop] 14))
  284.  
  285. (defun skip-mim-whitespace (direction) (byte-code "ÂYƒÃ    d\"‚Ä    e\"‡" [direction mim-whitespace 0 skip-chars-forward skip-chars-backward] 4))
  286.  
  287. (defun inside-adecl-or-trailer-p (direction) (byte-code "ÁYƒ ÂÃ!‚hÄU†ÂÅ!‡" [direction 0 looking-at ":\\|!-" 58 "!-"] 3))
  288.  
  289. (defun sign (n) "\
  290. Returns -1 if N < 0, else 1." (byte-code "ÁYƒ
  291. ‚ Ç" [n 0 1 -1] 2))
  292.  
  293. (defun abs (n) "\
  294. Returns the absolute value of N." (byte-code "ÁYƒ
  295. ‚ [‡" [n 0] 2))
  296.  
  297. (defun next-char (direction) "\
  298. Returns preceding-char if DIRECTION < 0, otherwise following-char." (byte-code "ÁYƒ
  299. g‚ h‡" [direction 0] 2))
  300.